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DOUBLE DATA RATE SYNCHRONOUS SRAM 
WITH 100% BUS UTILIZATION 

Stanley A. Hronik 

BACKGROUND 

Field of the invention 

The present invention relates to memory circuits, and more particularly to 
synchronous static random access memories (SRAMs) capable of transferring two 
data items per clock cycle and 100% bus utilization. 

Description of related art 

Asynchronous SRAMs have no input or output registers. Accessing an 
asynchronous SRAM is slow because the address and control signals (and the write 
data in case of a write operation) presented to the SRAM can not be changed for 
the duration of the SRAM access. 

Synchronous SRAMs eliminate the requirement to hold the SRAM input 
signals (address, control, and data) during read or write operations by including 
clocked registers for storing the address, control, and read and write data. The set- 
up and hold times for the registers are typically much shorter than the time to 
access the memory array of the SRAM. This significantly reduces the SRAM's 
cycle time as viewed at the pins of the device, and thus the frequency of the system 
clock is increased. 

The input and output registers however, cause two clock cycles of latency 
in the relation between the read address and read data, and no latency between the 
write address and write data (i.e., address is clocked in and data is clocked out in 
two consecutive clock cycles for a read, and the address and data are clocked in in 
the same clock cycle for a write). This latency difference between read and write 
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operations causes the address bus to remain idle for two clock cycles when a read 
cycle is followed by a write cycle, and causes the data bus to remain idle for two 
clock cycles when a write cycle is followed by a read cycle (i.e., bus turnaround). 
The idle cycles reduce the system data bandwidth. 

5 Late write SRAMs partially correct the latency problem. In a late write 

SRAM, the number of idle cycles in a bus turnaround is reduced from two clock 
cycles to one by introducing one clock cycle of latency in the write. Zero bus 
turnaround (ZBT) synchronous SRAMs developed by Integrated Device 
Technology Inc. (Patent Number 5,828,606, issued October 27, 1998) eliminate 

10 idle cycles in a bus turn around by causing read and write operations to have the 
same clock cycle latency of two, and thus achieve 100% bus utilization. The two 
clock cycles of latency are however undesirable. Fewer cycles of latency, e.g., one, 
provide faster data availability and potentially faster and easier system design. 
(The ZBT SRAM latency can be reduced to one clock cycle, but only if no 

15 registers are provided on the SRAM output. This is undesirable because it 
increases the minimum cycle time.) 

In all of the above SRAMs, at most one data item is transferred per clock 
cycle in either a read or a write operation. Double data rate (DDR) SRAMs 
transfer data into or out of the device on both the rising and falling clock edges, 

20 thus doubling the data transfer rate without increasing the clock frequency. One 
such device is the DDR late-write SRAM known as Claymore or MSUG-2 
developed by a private consortium known as the Motorola Semiconductor Users 
Group (MSUG). This device was designed for high performance workstation level 
2 cache operating in a point-to-point environment with data rates in excess of 

25 500MHz. While the Claymore device meets the needs for increased bandwidth in 
high performance communications applications, the lost clock cycle in every bus 
turn around (associated with every late write device) results in inefficient use of the 
address and data buses. 
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Thus, there is a need for a synchronous DDR SRAM capable of 100% bus 
utilization with fewer clock cycles of latency than the ZBT SRAM. 

SUMMARY 

A synchronous memory circuit is capable of double data transfer rate per 
5 clock cycle, 100% bus utilization (i.e., no idle clock cycles in bus turn arounds), 
and has only one clock cycle of latency in each of read and write burst operations. 

The synchronous memory circuit includes: an address bus for receiving an 
address; at least two memory blocks; and a data bus for receiving a data item for 
transfer to or from the at least two memory blocks, wherein in two consecutive 
10 clock cycles at least a first and a second write data items corresponding to a first 
write burst operation are capable of being transferred to the memory circuit via the 
data bus and at least a first and second read data items corresponding to a first read 
burst operation are capable of being transferred from the memory circuit via the 
data bus. 

15 In another embodiment, the at least first and second write data items are 

provided on the data bus one clock cycle after the first write burst operation is 
initiated, and the at least first and second read data items are provided on the data 
bus one clock cycle after the first read burst operation is initiated. 

In another embodiment, the memory circuit further includes at least one 
20 input terminal for receiving at least one read/write control signal for indicating a 
read burst or a write burst operation, wherein each of the first write burst operation 
and the first read burst operation is initiated upon a rising edge of a clock cycle by 
asserting the read/write control signal to indicate a write burst or a read burst 
operation and providing a burst address at the address bus both prior to the rising 
25 edge of the clock cycle. 

In another embodiment, the first write burst operation comprises writing at 
least a third and fourth write data items to respective two memory blocks so that 
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writing the third write data item overlaps with writing the fourth write data item, 
the at least third and fourth write data items corresponding to a last write burst 
operation prior to the first write burst operation. In another embodiment, each of 
the at least third and fourth write data items is written in one clock cycle, and 
writing the third write data item overlaps with writing the fourth write data item 
during half a clock cycle. 

In another embodiment, the first read burst operation comprises reading the 
at least first and second read data items from respective two memory blocks so that 
reading the first read data item overlaps with reading the second read data item. In 
another embodiment, each of the at least first and second read data items is read in 
one clock cycle, and reading the first read data item overlaps with reading the 
second read data item during half a clock cycle. 

In another embodiment, the memory circuit further includes an output 
circuit for receiving the at least first and second read data items from respective at 
least two memory blocks in the first read burst operation and allowing the at least 
first read data item to be provided on the data bus half a clock cycle after the first 
read burst operation is initiated, and allowing the second read data item to be 
provided on the data bus one clock cycle after the first read burst operation is 
initiated. 

In another embodiment, the output circuit includes a multiplexer for 
receiving a clock signal and the at least first and second read data items and 
sequentially transferring to an output bus of the multiplexer the at least first and 
second read data items in accordance with the state of the clock signal, and an 
output buffer for receiving the at least first and second read data items from the 
output bus of the multiplexer and providing the at least first and second read data 
items to the data bus when enabled, wherein the output buffer is enabled only when 
a valid read data item is to be provided on the data bus so that no external tracking 
of the progress of a read burst operation is required. 
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In another embodiment, the memory circuit is a static random access 
memory (SRAM). 

A method of accessing the synchronous memory circuit includes the acts 
of: (A) initiating a first write burst operation for sequentially transferring at least a 
5 first and second write data items to the memory circuit in a first clock cycle; and 
(B) initiating a first read burst operation for sequentially transferring at least a first 
and second read data items from the memory circuit in a second clock cycle, 
wherein the first and second clock cycles are two consecutive clock cycles. 

In another embodiment, the method further comprises: (C) initiating the 
10 first write burst operation in a third clock cycle, the first clock cycle being the next 
sequential clock cycle after the third clock cycle; and (D) initiating the first read 
burst operation in a fourth clock cycle, the second clock cycle being the next 
sequential clock cycle after the fourth clock cycle. 

In another embodiment, act (C) comprises: (E) asserting a read/write 
15 control signal on an input terminal of the memory circuit to indicate a write burst 
operation prior to a rising edge of the third clock cycle; and (F) providing a first 
write burst address on an address bus of the memory circuit prior to the rising edge 
of the third clock cycle. Act (D) comprises: (G) asserting the read/write control 
signal to indicate a read burst operation prior to a rising edge of the fourth clock 
20 cycle; and (H) providing a first read burst address on the address bus prior to the 
rising edge of the fourth clock cycle. 

In another embodiment, the memory circuit includes two memory blocks 
and act (A) comprises: (I) writing at least a third and fourth write data items to 
respective two memory blocks so that writing the third write data item overlaps 
25 with writing the fourth write data item, the at least third and fourth write data items 
corresponding to a last write burst operation prior to the first write burst operation. 
In another embodiment, act (I) comprises: (J) writing the third write data item in 
one clock cycle; and (K) writing the fourth write data item in one clock cycle, 
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wherein writing the third write data item overlaps with writing the fourth write data 
item during half a clock cycle. 

In another embodiment, act (B) comprises: (L) reading the at least first and 
second read data items from respective two memory blocks so that reading the first 
5 read data item overlaps with reading the second read data item. In another 

embodiment, act (L) comprises: (M) reading the first read data item in one clock 
cycle; and (N) reading the second read data item in one clock cycle, wherein 
reading the first read data item overlaps with reading the second read data item 
during half a clock cycle. 

10 Other features and advantages of the invention are described below. The 

invention is defined by the appended claims. 

BRIEF DESCRIPTION OF THE DRAWINGS 

The present invention may be better understood, and its numerous objects, 
features, and advantages made apparent to those skilled in the art by referencing 
15 the accompanying drawings. 

Fig. 1 is a block diagram of a preferred embodiment of a double data rate 
SRAM in accordance with the present invention. 

Fig. 2 is a sample timing diagram showing the waveforms for some signals 
in the Fig. 1 block diagram. 

10 The use of the same reference symbols in the drawings indicates similar or 

identical items. 

DESCRIPTION OF PREFERRED EMBODIMENTS 

Fig. 1 is a block diagram of a DDR integrated SRAM 10. SRAM 10 is a 
burst synchronous SRAM capable of 100% bus utilization (e.g., no idle cycles in a 
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bus turn around) with only one clock cycle latency between address and data for 
both read and write operations. 

SRAM 10 has an address bus 201 for receiving an address, a data bus 202 
for providing read data and receiving write data, three input terminals 141 5 142, 
and 203 for receiving the respective control signals CS , WE , and OE , and an 
input terminal 200 for receiving the system clock CLK. SRAM 10 includes two 
identical memory blocks 20 and 30, five clocked registers 40, 50, 60, 70, and 1 10, 
two multiplexers 80 and 120, a comparator 90, a 3-state output buffer 130, and four 
logic gates 67, 73, 100, and 140. The five clocked registers are clocked by the 
rising edges of the clock signal at their respective CK input terminals. However, 
the invention is not limited to the registers being clocked by the rising edges, or by 
any other particular features or circuitry, except as defined by the appended claims. 

OR gate 140 is a two input gate with its first and second input terminals 
connected to CS terminal 141 and WE terminal 142 respectively, and its output 
terminal connected to lead 143. Register 110 has: an input bus II connected to 
address bus 201, and a corresponding output bus Ql ; an inverting input terminal 
CE connected to lead 143; and an input terminal CK connected to CLK terminal 
200, Comparator 90 has a first input bus 91 connected to output bus Ql of register 
1 10, a second input bus 92 connected to address bus 201, and an output terminal 
93. Mux 80 is a two to one mux and has a first input bus 81 connected to address 
bus 201, a second input bus 82 connected to output bus Ql of register 1 10, a 
control input terminal 84 connected to lead 143, and an output bus 83. Mux 80 
selects the data on one of its two input buses for transfer to its output bus in 
accordance with the following table: 
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Control input 84 Output (bus 83) 

0 Address at bus 82 

1 Address at bus 8 1 
5 Table 1 

Register 40 has: an input terminal II connected to CS terminal 141, and a 
corresponding output terminal Ql connected to lead 43; an input terminal 12 
connected to lead 143, and a corresponding output terminal Q2 connected to lead 
44; an input terminal 13 connected to output terminal 93 of comparator 90, and a 

10 corresponding output terminal Q3 connected to lead 45; an input bus 14 connected 
to output bus 83 of mux 80, and a corresponding output bus Q4 connected to bus 
46; and an input terminal CK connected to CLK terminal 200. Register 50 has: an 
input bus II connected to data bus 202, and a corresponding output bus Ql ; an 
inverting input terminal CE connected to lead 44, and an input terminal CK 

15 connected to CLK terminal 200. Inverter 100 has an input terminal connected to 
CLK terminal 200, and an output terminal connected to lead 102. 

Register 60 has: an input terminal II connected to lead 43, and a 
corresponding inverting output terminal Ql ; an input terminal 12 connected to lead 
45, and a corresponding output terminal Q2; an input terminal 13 connected to lead 

20 44, and a corresponding output terminal Q3 connected to lead 71 ; an input bus 14 
connected to bus 46, and a corresponding output bus Q4; and an input terminal CK 
connected to lead 102. Register 70 has: an input bus II connected to data bus 202, 
and a corresponding output bus Ql; an inverting input terminal CE connected to 
the output terminal Q3 of register 60, and an input terminal CK connected to lead 

25 102. 

Mux 120 is a four to one multiplexer and has a first input bus 121, a second 
input bus 122 connected to output bus Ql of register 50, a third input bus 123, a 
fourth input bus connected to output bus Ql of register 70, a first control input 
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terminal 125 connected output terminal Q2 of register 60, a second control input 
terminal 126 connected to CLK terminal 200, and an output bus connected to bus 
127. Mux 120 selects the data on one of its four input buses for transfer to its 
output bus in accordance with the following table: 

5 Control input Control input 

1 26 (CLK) 1 25 Output (bus 1 27) 

0 0 Dout 24 

0 1 Din 23 
10 1 0 Dout 34 

1 1 Din 33 
Table 2 

Output buffer 130 has an input bus connected to bus 127, a control input 
terminal connected to lead 74, and an output bus connected to data bus 202. AND 
15 gate 67 is a two input gate, and has an inverting input terminal connected to OE 
terminal 203, a second input terminal connected to lead 54, and an output terminal 
connected to lead 74. AND gate 73 is a two input gate with its first and second 
input terminals respectively connected to inverting output terminal Ql and output 
terminal Q3 of register 60, and its output terminal connected to lead 54. 

20 Gate 300 is a two input, two output AND gate, and has a first input terminal 

connected to lead 54, a second input terminal connected to CLK terminal 200, a 
first output terminal 301 for providing EchoCLK signal and a second inverting 
output terminal 302 for providing EchoCLK signal. Gate 300 also has a control 
input terminal connected to OE terminal 203. 

15 Memory blocks 20 and 30 are internally identical, each having a read/write 

control input terminal W , an address bus Add, a data-in bus Din, and a data-out 
bus Dout. Memory block 20 has: W terminal 21 connected to lead 44, Add bus 22 
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connected to bus 46, Din bus 23 connected to output bus Ql of register 50, and 
Dout bus 24 connected to input bus 121 of mux 120. Memory block 30 has: W 
terminal 3 1 connected to output terminal Q3 of register 60, Add bus 32 connected 
to output bus Q4 of register 60, Din bus 33 connected to output bus Ql of register 
70, and Dout bus 34 connected to input bus 123 of mux 120. Memory blocks 20 
and 30 operate asynchronously. If the W input of block 20 or 30 is low, the block 

stores the data provided on its input Din. If W is high, the block provides read 
data on output Dout. 

Fig. 2 is a sample timing diagram showing the waveforms for CLK, CS , 
WE , address, data, EchoCLK, EchoCLK and some of the internal leads of SRAM 
10. Twelve clock cycles (N to N+l 1) are illustrated. Each clock cycle starts at the 
rising edge of system clock CLK. Shaded areas indicate the times that the signal is 
allowed to change. The number next to each signal name corresponds to the 
numbered buses, terminals, and leads in Fig. 1 . 

Data is transferred to or from SRAM 10 in bursts of two data items. The 
two data items are both either read or write data. Each burst is initiated on the 
rising edge of clock CLK. In a read burst, the address is provided to memory block 
20 (through register 40) on the rising edge starting the burst operation. For 
example, in the read started on the rising edge of cycle N+3 in Fig. 2, the read 
address A6 is provided to block 20 on the rising edge of N+3. The same address is 
provided to memory block 30 (through register 60) on the next falling edge. 
Memory blocks 20 and 30 provide respective data on their respective Dout buses. 
Multiplexer 120 selects the Dout bus from block 20 when clock CLK becomes low 
(i.e. starting the falling edge), and selects the Dout output from memory block 30 
when the system clock becomes high (starting the rising edge of the next clock 
cycle). 
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In a write burst, the address is latched by SRAM 10 before the data. For 
example, in the burst initiated in clock cycle N, the write address AO is latched by 
register 1 10 from bus 201 at the rising edge of cycle N, the first data item DOw is 
latched by register 50 from bus 202 at the rising edge of cycle N+l, and the second 
5 data item Dlw is latched by register 70 from bus 202 at the falling edge of cycle 
N+l. However, the write address is delayed by register 40, so the registers 40 and 
50 supply the write address and the first data item to memory block 20 at the same 
time. Registers 60 and 70 supply the write address and the second data item to 
memory block 30 at the same time. 

10 

If the write operation is immediately followed by a read or a dead cycle, the 
write data are not written to memory blocks 20 and 30. The write data are stored in 
registers 50 and 70, and the write address is stored in register 1 10, until the next 
write operation. 

15 We now describe the write, read sequence on the example of the A 12 write, 

A14 read bursts in more detail. The write burst at address A12 is initiated at the 
rising edge of clock cycle N+6 by asserting a low voltage on the WE terminal 142 
( CS signal must be active, i.e., a low voltage). A burst of two data items D12w 
and D13w corresponding to the external address A 12 are provided at data bus 202 

20 at the respective rising and falling edges of clock cycle N+7. Signal R/W at the 
output of OR gate 140 (which is the same as the WE signal when CS is active) is 
used to set up registers 1 10, 50, and 70 for storing the respective address A12 and 
data D12w and D13w by pulling their inverted CE input terminals low at the 
proper time. The CE terminal of register 1 10 is pulled low just prior to the N+6 

25 cycle. The CE terminal of register 50 is pulled low through register 40 upon the 
rising edge of clock cycle N+6. The CE terminal of register 70 is pulled low 
through registers 40 and 60 upon the falling edge of clock cycle N+6. 

Thus, address A 12 is stored in register 1 10 at the rising edge of clock cycle 
N+6, and data D12w and D13w are stored in the respective registers 50 and 70 at 
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the respective rising and falling edges of the next clock cycle N+7. The address 
and data are maintained in these registers until the next write cycle, i.e., cycle 
N+10. At the rising edge of clock cycle N+10, the low WE signal initiating the 
write burst at address A20 is provided to the W terminal of memory block 20 
5 through OR gate 140 and register 40. This causes data D12w in register 50 to be 
written to memory block 20 at the internal address A 12. Haifa clock cycle later, at 
the falling edge of clock cycle N+10, WE low is provided to the W terminal of 
memory block 30 through register 60. This causes data D13w in register 70 to be 
written to memory block 30 at the internal address A 12. 

10 Note that address A12 stored in register 1 10 is selected by mux 80 just prior 

to clock cycle N+10 when the R/W signal is low (in accordance with Table 1), and 
is provided to the Add bus 22 of memory block 20 through register 40 at the rising 
edge of clock cycle N+10. Half a clock cycle later, at the falling edge of clock 
cycle N+10, address A12 is provided to the Add bus 32 of memory block 30 

1 5 through register 60. 

Also note that the WE low signal initiating the A12 write burst in the N+6 
clock cycle also causes data D8w and D9w (stored in respective registers 50 and 70 
during the preceding write burst operation) to be written to respective memory 
blocks 20 and 30 at the internal address A8 (stored in registers 1 10 and 60 during 
20 the preceding write burst operation). 

The read burst at address A14 is initiated at the rising edge of clock cycle 
N+7 by asserting a high voltage on the WE terminal 142 (the CS signal must be 
active). Two data items D14r and D15r corresponding to the external address A14 
are sequentially provided on data bus 202 at the respective rising and falling edges 
25 of clock cycle N+8. With a high WE signal, registers 110, 50, and 70 are disabled 
through their respective CE input terminals at the proper time. The high WE 
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signal propagates through OR gate 140 and causes mux 80 to select address A14 
on address bus 201 in accordance with Table 1. 

Upon the rising edge of clock cycle N+7, address A14 and the high WE 
signal are clocked in by register 40 and presented respectively to Add bus 22 and 
5 W terminal 21 of memory block 20. Register 40 holds A14 and the high WE 
signal for the full clock cycle N+7. Memory block 20 provides data D14r, which 
corresponds to the internal address A 14, to input bus 121 of mux 120 via Dout bus 
24. In accordance with Table 2, mux 120 selects its input bus 121 when clock 
CLK becomes low (i.e., data D14r can pass through mux 120 on or after the falling 
10 edge of clock cycle N+7). 3 -state output buffer 130 provides the data on its input 
bus 127 to data bus 202 when the signal at its 3-state input terminal 74 goes high. 
Thus, data D14r is provided on data bus 202 in the second half of clock cycle N+7 
as shown in Fig. 2 (note that the OE signal must be active). 

The address A14 and the high WE signal are passed on to memory block 
15 30 by register 60 upon the falling edge of clock cycle N+7. Register 60 holds A14 
and the high WE signal for a full clock cycle. Memory block 30 provides data 
D15r, which corresponds to the internal address A 14, to input bus 123 of mux 120 
via Dout bus 34. In accordance with Table 2, mux 120 selects its input bus 123 
when clock CLK becomes high (i.e., data D15r can pass through mux 120 on or 
20 after the rising edge of clock cycle N+8). Output buffer 130 then provides data 
D15r to data bus 202 since its 3-state signal is high, as shown in Fig. 2. 

The 3-state signal of output buffer 130 is controlled by the WE signal 
through registers 40 and 60, and AND gates 73 and 67. The 3-state signal is used 
to ensure that output buffer 130 is enabled only for read bursts. As indicated in 
25 Fig. 2, the 3-state signal is active only if and whenever valid read data is provided 
on data bus 202. This allows the initiation of a read burst without requiring 
external tracking of the progress of the burst. 
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In a read burst, each read data item can be made available on data bus 202 
for an entire half cycle if the address-to-data time of memory blocks 20 and 30 is a 
half cycle or less. For example, data item D6r can be provided on data bus 202 
starting at the falling edge of cycle N+3, and not later as in Fig. 2. However, for a 
given address-to-data time of memory blocks 20 and 30, the ability to provide the 
read data item on data bus 202 more than a half cycle after the initiation of the read 
burst enables the clock frequency to be increased compared to the case wherein the 
read data item is required to be available on data bus 202 within a half cycle after 
the initiation of the read burst. 

Because of the use of mux 120 instead of an output register, the time from 
clock CLK to data out is similar to a registered output, but the access of memory 
blocks 20, 30 is asynchronous. This enables a faster memory access time by not 
requiring the data setup time prior to clock of an output register since the mux 
selection can be made as the data is propagating through device 10. Also, by 
eliminating the output register, the latency between read address and read data is 
reduced from two clock cycles to one. Mux 120 may be replaced by a controlled 
selection device, for example, a driver which can be enabled at the appropriate time 
in the cycle. 

Note that the advantages of using mux 120 can also be realized in 
conventional synchronous memory devices (e.g., synchronous DRAMs and 
PROMs) by using a clock-controlled selection circuit instead of the conventional 
output register. The selection circuit similar to mux 120 allows read data to pass 
through to the output bus if the clock condition is met. In other words, the 
selection circuit is enabled by the clock signal half a clock cycle after the read 
address is clocked in by the input register (e.g., register 40). The selection circuit 
may be a simple transmission gate controlled by the clock signal. 

As the above description of the A12 read burst, A14 write burst sequence 
indicates, having two separate memory blocks 20, 30 allows a read from one 
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memory block to overlap with a write to the other memory block. For example, in 
the first half of cycle N+7, the data item D13w is being written to memory block 
30 while the data item D14r is being read from memory block 20. 

A special condition arises when the read address equals the latest preceding 
write address. Under this condition, the latest preceding write data have not yet 
been written to the memory blocks 20 and 30, but a read request has been issued 
for the data. The read is handled as follows. 

At the start of the latest preceding write burst, the write address was written 
to register 1 10 as described above. After that, no writes have taken place, so the 

CS signal or the WE signal, or both, have been high on the rising CLK edges. 
Hence, the CE input of register 1 10 has been high on the rising CLK edges, so 
register 1 10 has continued to store the latest preceding write address. Comparator 
90 always compares an incoming address received at its input bus 92 with the write 
address stored in register 110. If the two addresses match, comparator 90, through 
registers 40 and 60, causes the control input terminal 125 (marked as "=") of mux 
120 to go high at the appropriate time. In accordance with Table 2, if clock CLK is 
low, mux 120 selects the data provided by register 50 on input bus 122 rather than 
the data provided by memory block 20 on input bus 121 . If clock CLK is high, 
mux 120 selects the data provided by register 70 on input bus 124 rather than the 
data provided by memory block 30 on input bus 123. 

Once a burst (read or write) is initiated, it progresses to completion. Thus, 
control signals WE and CS and the address need not be maintained throughout 
the burst. If dead cycles are required, they can be inserted using the CS and/or 
OE control signals. 

The burst length can be made greater than two by providing a 
corresponding greater number of internal memory blocks. As with the length of 
two, longer bursts are carried out as the same internal address is passed from one 
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memory block to the next on each edge of the clock. A longer burst causes the 
data bus to be occupied for more clock cycles, and allows the address bus and the 
control signal WE to be free for longer periods. 

The data rate on SRAM data bus 202 is twice the data rate on any one of 
5 the Dout buses of memory blocks 20 and 30. One reason for this is that the reading 
from memory blocks 20 and 30 overlaps. A full clock cycle is available for each 
read from each memory block. For example, in a read from memory block 20 in 
the A6 read burst, A6 is provided to block 20 at the start of clock cycle N+3, and 
the data D6r can be read out to data bus 202 any time before the end of cycle N+3, 
10 provided the set-up and holding times for the reading (target) device (not shown) 
are satisfied. The block 30 read is also allowed to take one full cycle starting at the 
falling edge of cycle N+3. The two reads overlap in the second half of cycle N+3. 

Similarly, the writes to blocks 20 and 30 overlap. Although the actual write 
to memory blocks 20 and 30 occur in a write cycle other than the one to which the 
15 write data corresponds, nevertheless, registers 50 and 70 are clocked at half the 

speed at which the data are provided on data bus 202. A whole cycle is allowed to 
write to a memory block, and one half a cycle is allowed for overlap. 

Further, in a write burst following a read burst, a write to block 20 and a 
read from block 30 overlap. Similarly, if a read burst follows a write burst, a read 
20 from block 20 and a write to block 30 overlap. 

Hence, the external address on bus 201 is at half the toggle rate of the clock 
CLK for a burst of two. If longer burst lengths are implemented, the external 
address could be even slower. 

SRAM 10 can be disabled during any clock cycle by holding CS high on 
25 the rising edge of the clock. While disabled, SRAM 10 completes any activities 
initiated in previous clock cycles. Internally, SRAM 10 performs a read operation 
on whatever address is on address bus 201 at the initiation of the disable cycle. 
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This is because when CS is high, the R/W signal on lead 143 goes high (i.e., a 

read operation). But, no data will be driven to data bus 202 because the high CS 
signal propagates through registers 40 and 50, and AND gates 73 and 67, and 
disables buffer 130 prior to the time the data for the disabled cycle reaches output 
5 buffer 130. 

SRAM 1 0 can be configured to have a dedicated data-in bus for write data 
and a dedicated data-out bus for read data by simply connecting the II input bus of 
registers 50 and 70 to the data-in bus, and the output bus of output buffer 130 to the 
data-out bus. With separate data buses, there is no bus turned around and thus 
10 there are no data contention issues. However, in a read cycle the data-in bus is 
idle, and in a write cycle the data-out bus is idle. 

Typically, in a read operation the clock along with the read instruction are 
delivered to the SRAM and the SRAM returns the indicated response to a target 
device. In very high speed clocking arrangements and where the target device is a 
15 clocked device, coordinating the clock with the return data is difficult because of 
latencies and differences in routing of the data and the clock. The result is that the 
data read from the SRAM is not coordinated with the clock (the data often arrives 
at the target device later than that allotted by the clock cycle), and read errors at the 
target device occur. 

20 To eliminate the potential read errors at the target device, dedicated clock 

signals EchoCLK and EchoCLK are provided for being routed to the target device 
along with the read data. By ensuring that the EchoCLK and EchoCLK timing 
coincide with the read data availability at the data bus 202, any potential timing 
skews between the clock and the data at the target device reading the SRAM 10 are 

25 eliminated. Further, the EchoCLK and EchoCLK signals are active only during 
read bursts (i.e., these signals change with clock CLK only when the 3-state signal 
is high). This simplifies the system design by eliminating the need for a separate 
signal notifying the target device of the data transfer from SRAM 10. 
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As shown in Fig. 1, EchoCLK / EchoCLK signals are generated by AND 

gate 300. Gate 300 allows EchoCLK / EchoCLK signals to respond to the CLK 

signal only when read data is provided on data bus 202. EchoCLK / EchoCLK 

signals do not respond to the CLK signal when either the OE control signal is 
5 high, or when lead 54 is low (i.e. when data bus 202 is in 3-state). Gate 300 should 
be designed to have a gate delay shorter than or equal to that of mux 120 plus 
output buffer 130. This ensures that EchoCLK can be used externally with a zero 
hold time register (not shown) to capture any data appearing on data bus 202. The 

EchoCLK / EchoCLK signals help the system achieve the maximum possible 
10 setup time on the target device, while the hold time is minimized. 

The EchoCLK signal is provided to facilitate clocking of data on both the 
rising and falling edges of clock CLK. The rising edge of EchoCLK can be used to 

clock rising edge data, and the rising edge of EchoCLK can be used to clock 

falling edge data. Also, EchoCLK and EchoCLK can be used differentially if the 

15 application requires it. Note that the EchoCLK and EchoCLK signals are not 
necessary for the proper operation of SRAM 1 0, and merely support the external 

use of the SRAM. Thus, the EchoCLK and EchoCLK signals and the associated 
circuitry may be eliminated if the application does not use them. 

In accordance with the invention, among other features and advantages, 
20 double data transfer rate per clock cycle, only one clock cycle of latency in each of 
read and write bursts, and 100% bus utilization (i.e., no idle clock cycles in bus 
turn arounds) are achieved. 

The dual data rate SRAM of the present invention is intended for but not 
limited to high speed read/write applications, such as network switches and routers, 
25 which receive and store data in a memory before data are transmitted (here both 
read and write can be carried out without interfering with each other), or graphics 
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applications where data is loaded into the graphics memory and then fed out 
continuously to a video screen. 

The above description of the present invention is intended to be illustrative 
and not limiting. The invention is not limited to any particular circuitry or timing, 

5 to the number of external address bits provided to the memory, to any signal being 
provided on a rising or falling edge, or to edge-sensitive circuitry. The invention is 
not limited to an integrated SRAM 10, i.e., discrete components may be used to 
implement SRAM 10. The invention is not limited to any particular type of 
memory blocks 20 and 30, which can be asynchronous, synchronous, or perhaps 

10 other types of memories, known or to be invented. The invention includes all 
variations and modifications falling within the scope of the appended claims. 
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CLAIMS 

What is claimed is: 

1. A synchronous memory circuit comprising: 

an address bus for receiving an address; 

5 at least two memory blocks each of which is capable to be accessed at said 

address; and 

a data bus for receiving data items for transfer to or from the memory 

blocks, 

wherein in two consecutive clock cycles at least a first and a second write 
10 data items corresponding to a first write burst operation are capable of being 

transferred sequentially to the memory circuit via the data bus and at least a first 
and second read data items corresponding to a first read burst operation are capable 
of being provided sequentially by the memory circuit via the data bus. 

2. The memory circuit of claim 1 wherein the at least first and second 
15 write data items are provided on the data bus at least one clock cycle after the first 

write burst operation is initiated, and the at least first and second read data items 
are provided on the data bus at least one clock cycle after the first read burst 
operation is initiated. 

3. The memory circuit of claim 2 further comprising at least one input 
20 terminal for receiving at least one read/write control signal for indicating a read 

burst or a write burst operation, wherein each of the first write burst operation and 
the first read burst operation is initiated upon an edge of a clock cycle by asserting 
the read/write control signal to indicate a write burst or a read burst operation and 
providing a burst address at the address bus both prior to the rising edge of the 
25 clock cycle. 
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4. The memory circuit of claim 1 wherein in two and a half 
consecutive clock cycles at least a third and a fourth data items corresponding to a 
second write or read burst operation are capable of being transferred to or from 
respective at least two memory blocks and at least a fifth and sixth data items 
corresponding to a third write or read burst operation are capable of being 
transferred to or from respective at least two memory blocks. 

5. The memory circuit of claim 4 wherein transferring the at least third 
and fourth data items to or from the respective at least two memory blocks overlaps 
with transferring the at least fifth and sixth data items from respective at least two 
memory blocks during half a clock cycle. 

6. The memory circuit of claim 1 wherein the first write burst 
operation comprises writing at least a third and fourth write data items to respective 
two memory blocks so that writing the third write data item overlaps with writing 
the fourth write data item, the at least third and fourth write data items 
corresponding to a last write burst operation prior to the first write burst operation. 

7. The memory circuit of claim 6 wherein each of the at least third and 
fourth write data items is written in one clock cycle, and writing the third write 
data item overlaps with writing the fourth write data item during half a clock cycle. 

8. The memory circuit of claim 1 wherein the first read burst operation 
comprises reading the at least first and second read data items from respective two 
memory blocks so that reading the first read data item overlaps with reading the 
second read data item. 

9. The memory circuit of claim 8 wherein each of the at least first and 
second read data items is read in one clock cycle, and reading the first read data 
item overlaps with reading the second read data item during half a clock cycle. 

10. The memory circuit of claim 1 further comprising an output circuit 
for receiving the at least first and second read data items from respective at least 
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two memory blocks in the first read burst operation and allowing the first read data 
item to be provided on the data bus half a clock cycle after the first read burst 
operation is initiated, and allowing the second read data item to be provided on the 
data bus one clock cycle after the first read burst operation is initiated. 

5 11. The circuit of claim 1 0 wherein the output circuit is enabled only 

when a valid read data item is to be provided on the data bus so that no external 
tracking of the progress of a read burst operation is required. 

12. The memory circuit of claim 1 1 further comprising at least one 
input terminal for receiving at least one read/write control signal for initiating a 

10 read burst operation or a write burst operation, wherein the output circuit is enabled 
by a 3 -state signal generated from the read/write control signal. 

13. The memory circuit of claim 10 wherein the output circuit 
comprises a multiplexer for receiving a clock signal and the at least first and 
second read data items and sequentially transferring to an output bus of the 

15 multiplexer the at least first and second read data items in accordance with the state 
of the clock signal. 

14. The memory circuit of claim 10 further comprising at least two 
registers for providing both a burst address received at the address bus and at least 
one read/write control signal received at at least one input terminal of the memory 

20 circuit to the at least two memory blocks sequentially in one clock cycle. 

15. The circuit of claim 14 wherein at the initiation of the first read 
burst operation the at least two registers provide both a read burst address received 
at the address bus and the least one read/write control signal indicating a read burst 
operation to one of the at least two memory blocks, and half a clock cycle after the 

25 initiation of the first read burst operation the at least two registers provide both the 
read burst address and the at least one read/write control signal indicating a read 
burst operation to the other one of the at least two memory blocks. 
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16. The circuit of claim 14 wherein the at least two registers are serially 
connected, and one of the at least two registers receives the clock signal and the 
other register receives the compliment of the clock signal. 

17. The memory circuit of claim 1 wherein in the first write burst 

5 operation at least a third and fourth write data items are written to respective at 
least two memory blocks, the third and fourth write data items corresponding to a 
last write burst operation prior to the first write burst operation. 

18. The memory circuit of claim 17 further comprising a multiplexer for 
selecting for transfer to the at least two memory blocks one of a write burst address 

10 stored in a first register and a burst address provided on the address bus, wherein in 
the first write burst operation the multiplexer selects a first write burst address 
stored in the first register, the first write burst address corresponding to the last 
write burst operation, and in the first read burst operation the multiplexer selects a 
first read burst address provided on the address bus 

15 19. The memory circuit of claim 1 8 wherein the first register holds a 

write burst address until a next write burst is initiated. 

20. The memory circuit of claim 17 wherein the third write data item is 
written to one of the at least two memory blocks at the initiation of the first write 
burst operation, and the fourth write data item is written to the other one of the at 

20 least two memory blocks half a clock cycle after the initiation of the first write 
burst operation. 

21 . The memory circuit of claim 20 further comprising at least two 
registers for storing respective at least two write data items provided on the data 
bus in a write burst operation, wherein in the last write burst operation the at least 

25 third and fourth write data items are stored in the respective at least two registers, 
the at least two registers providing the third write data item to one of the at least 
two memory blocks at the initiation of the first write burst operation and providing 
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the fourth write data item to the other one of the at least two memory blocks half a 
clock cycle after the initiation of the first write burst operation. 

22. The memory circuit of claim 21 wherein one of the at least two 
registers receives a clock signal and the other one of the at least two registers 

5 receives the complement of the clock signal. 

23. The memory circuit of claim 21 wherein if a read burst address for 
the first read burst operation and a write burst address for the first write burst 
operation are the same and the first write burst operation is followed by the first 
read burst operation, in the first read burst operation the at least first and second 

10 write data items stored in respective at least two registers in the first write burst 
operation are sequentially provided at the data bus. 

24. The memory circuit of claim 22 further comprising a comparator for 
comparing a burst address of a current burst operation with a write burst address of 
a preceding write burst operation stored in a third register, wherein in the first read 

1 5 burst operation the comparator compares a read burst address corresponding to the 
first read burst operation with a write burst address corresponding to the first write 
burst operation and allows the at least first and second write data items stored in 
respective two registers in the first write burst operation to be provided at the data 
bus if the read burst address and the write burst address are the same and the first 

20 write burst operation is followed by the first read burst operation. 

25. The memory circuit of claim 1 wherein the memory circuit is a 
static random access memory (SRAM). 

26. The memory circuit of claim 1 further comprising a circuit for 
generating an echo clock signal from the clock signal such that the echo clock 

25 signal is active only when a read data item is provided on the data bus. 

27. The memory circuit of claim 1 wherein the data bus comprises: 
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a data-in bus for receiving write data items; and 
a data-out bus for providing read data items. 

28. A method of accessing a synchronous memory circuit, the method 
comprising the: 

5 (A) initiating a first write burst operation for sequentially transferring at 

least a first and second write data items to the memory circuit in a first clock cycle; 
and 

(B) initiating a first read burst operation for sequentially transferring at least 
a first and second read data items from the memory circuit in a second clock cycle, 

10 wherein the first and second clock cycles are two consecutive clock cycles. 

29. The method of claim 28 further comprising: 

(C) initiating the first write burst operation in a third clock cycle, the first 
clock cycle being the next sequential clock cycle after the third clock cycle; and 

(D) initiating the first read burst operation in a fourth clock cycle, the 
15 second clock cycle being the next sequential clock cycle after the fourth clock 

cycle. 

30. The method of claim 29 wherein: 

act (C) comprises: 

(E) asserting a read/write control signal on an input terminal 
20 of the memory circuit to indicate a write burst operation prior to a 

rising edge of the third clock cycle; and 
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(F) providing a first write burst address on an address bus of 
the memory circuit prior to the rising edge of the third clock cycle, 
and 

act (D) comprises: 

5 (G) asserting the read/write control signal to indicate a read 

burst operation prior to a rising edge of the fourth clock cycle; and 

(H) providing a first read burst address on the address bus 
prior to the rising edge of the fourth clock cycle. 

3 1 . The method of claim 28 wherein the memory circuit includes at 
10 least two memory blocks, the method further comprising: 

(I) transferring at least a third and fourth data items corresponding to a 
second burst operation to or from respective at least two memory blocks; and 

(J) transferring at least a fifth and sixth data items corresponding to a third 
burst operation to or from respective at least two memory blocks, 

15 wherein acts (I) and (J) are carried out in two and half consecutive clock 

cycles. 

32. The method of claim 3 1 wherein said transferring the at least third 
and fourth data items to or from respective at least two memory blocks overlaps 
with said transferring the at least fifth and sixth data items to or from respective at 

20 least two memory blocks during half a clock cycle. 

33. The method of claim 28 wherein the memory circuit includes two 
memory blocks and act (A) comprises: 

(K) writing at least a third and fourth write data items to respective two 
memory blocks so that writing the third write data item overlaps with writing the 
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fourth write data item, the at least third and fourth write data items corresponding 
to a last write burst operation prior to the first write burst operation 

34 The method of claim 33 wherein act (K) comprises: 

(L) writing the third write data item in one clock cycle; and 

5 (M) writing the fourth write data item in one clock cycle, 

wherein said writing the third write data item overlaps with said writing the 
fourth write data item during half a clock cycle. 

35. The method of claim 28 wherein the memory circuit includes two 
memory blocks and act (B) comprises: 

10 (N) reading the at least first and second read data items from respective two 

memory blocks so that reading the first read data item overlaps with reading the 
second read data item. 

36. The method of claim 35 wherein act (N) comprises: 
(O) reading the first read data item in one clock cycle; and 

15 (P) reading the second read data item in one clock cycle, 

wherein said reading the first read data item overlaps with said reading the 
second read data item during half a clock cycle. 

37. The method of claim 28 further comprising: 

(Q) generating an echo clock signal from a clock signal, the echo clock 
20 signal being active only when a read data item is read from the memory circuit. 

38. A synchronous memory circuit comprising: 
an address bus for receiving a burst address; 
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two memory blocks; 

data bus for transferring data corresponding to the burst address to or from 
the two memory blocks; 

a control input terminal for receiving a read/write control signal for 
5 indicating a read burst or a write burst operation, wherein a burst operation is 
initiated upon a rising edge of a clock cycle by asserting the read/write control 
signal to indicate a write burst or a read burst operation and providing an address at 
the address bus both prior to the rising edge of the clock cycle; 

an output circuit for receiving two read data items from respective two 
10 memory blocks in a first read burst operation and allowing one of the two read data 
items to be provided on the data bus half a clock cycle after the first read burst 
operation is initiated, and allowing the other one of the two read data items to be 
provided on the data bus one clock cycle after the first read burst operation is 
initiated; and 

15 a first and second registers for storing respective two write data items 

provided on the data bus in a first write burst operation, wherein one of the two 
write data items is written to one of the two memory blocks at the initiation of a 
next write burst operation following the first write burst operation, and the other 
one of the two write data items is written to the other one of the two memory 

20 blocks half a clock cycle after the initiation of the next write burst operation, 

wherein in two consecutive clock cycles the two write data items are 
capable of being transferred to the memory circuit via the data bus and the two read 
data items are capable of being transferred from the memory circuit via the data 
bus. 

25 39. The memory circuit of claim 38 further comprising: 


-28- 


507274 vl 


a multiplexer for selecting for transfer to the two memory blocks one of a 
write burst address stored in a third register and a burst address provided on the 
address bus, wherein in the next write burst operation the multiplexer selects a first 
write burst address stored in the third register, the first write burst address 
5 corresponding to the first write burst operation, and in the first read burst operation 
the multiplexer selects a first read burst address provided on the address bus; and 

a fourth and fifth serially connected registers for providing both the 
read/write control signal and the burst address selected by the multiplexer to one of 
the two memory blocks at the initiation of a burst operation and to the other one of 
10 the two memory blocks half a clock cycle after the initiation of the burst operation. 

40. The memory circuit of claim 39 wherein each of the first, third, and 
fourth registers receives the clock signal, and each of the second and fifth registers 
recieves the complement of the clock signal. 

41. The memory circuit of claim 38 further comprising a comparator for 
15 comparing a burst address at the address bus with a write burst address stored in a 

third register, wherein in a second read burst operation corresponding to a second 
read burst address if the second read burst address is the same as a second write 
burst address stored in the third register the comparator causes a first and second 
write data items stored in the respective first and second registers to be provided at 
20 the data bus, the first and second write data items and the second write burst 

address corresponding to a last write burst operation before the second read burst 
operation. 

42. The memory circuit of claim 41 wherein the output circuit 
comprises a multiplexer having four input buses for receiving a respective four 

25 read data items two read data items from the respective two memory blocks and 
two read data items from the respective two first and second registers, and two 
control input terminals for receiving a respective clock signal and signal generated 
from the comparator, wherein the multiplexer selects one of the four read data 
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items for transfer to the data bus in accordance with the states of the clock signal 
and the signal generated from the comparator. 

43. The memory circuit of claim 38 wherein the output circuit 
comprises: 

5 a multiplexer for sequentially transferring to an output bus of the 

multiplexer the two read data items in accordance with the state of the clock signal; 
and 

an output buffer for receiving the two read data items from the output bus 
of the multiplexer and providing the two read data items to the data bus when 
10 enabled, wherein the output buffer is enabled only when a valid read data item is to 
be provided on the data bus so that no external tracking of the progress of a read 
burst operation is required. 

44. The memory circuit of claim 38 wherein each of the two memory 
blocks comprises an address bus for receiving a burst address, an input terminal for 

15 receiving a read/write control signal for indicating a read burst or a write burst 
operation, a data-in bus for receiving a write data item, and a data-out bus for 
providing a read data item, wherein each of the two memory blocks operates 
asynchronously. 

45. The memory circuit of claim 38 wherein the memory circuit is a 
20 static random access memory (SRAM). 

46. A synchronous memory circuit comprising: 
a first memory block; 

a data bus for transferring data to or from the first memory block; and 
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an output circuit for receiving a first read data item from the first memory 
block in a first read operation and allowing the first read data item to be provided 
on the data bus after half a clock cycle after the first read operation is initiated. 

47. The circuit of claim 46 wherein the output circuit comprises a 

5 transmission gate for selecting for transfer to the data bus the first read data item in 
accordance with the state of a clock signal. 

48. The memory circuit of claim 47 further comprising: 
an address bus for receiving an address; and 

a control input terminal for receiving a read/write control signal for 
10 indicating a read or a write operation, 

wherein the first read operation is initiated upon a rising edge of a clock 
cycle by asserting the read/write control signal to indicate a read operation and 
providing a first address at the address bus both prior to the rising edge of the clock 
cycle, the first data item corresponding to the first address. 

15 49. The memory circuit of claim 46 wherein the memory circuit further 

comprises a second memory block, the output circuit receiving a second read data 
item from the second memory block in the first read operation and allowing the 
second read data item to be provided on the data bus after one clock cycle after the 
first read operation is initiated. 

20 50. The memory circuit of claim 49 wherein the first read operation is a 

first read burst operation. 

5 1 . The circuit of claim 50 wherein the control circuit comprises a 
multiplexer for sequentially selecting for transfer to the data bus the first and 
second read data items in accordance with the state of a clock signal. 

25 52. The memory circuit of claim 5 1 a further comprising: 
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an address bus for receiving a burst address; and 

a control input terminal for receiving a read/write control signal for 
indicating a read burst or a write burst operation, 

wherein the first read burst operation is initiated upon a rising edge of a 
5 clock cycle by asserting the read/write control signal to indicate a read burst 
operation and providing a first burst address at the address bus both prior to the 
rising edge of the clock cycle, the first and second data items representing a burst 
of two data items corresponding to the first burst address. 

53. The circuit of claim 46 wherein the memory circuit is a static 

10 random access memory (SRAM), or a dynamic random access memory (DRAM), 
or a programmable read only memory (PROM). 

54. A memory circuit comprising: 

a clock terminal for receiving a clock signal; 
15 an address bus for receiving an address; 

a data bus for receiving write data and providing read data; and 
wherein the memory circuit is capable to perform a write burst operation in 
which the memory circuit receives one read address from the address bus and the 
memory circuit also receives, sequentially, two write data items from the data bus; 
20 wherein the memory circuit is capable to perform a read burst operation in 

which the memory circuit receives one write address on the address bus and the 
memory circuit provides, sequentially, two write data items on the data bus; 

wherein the memory circuit is capable to receive a new read or write 
address in each clock cycle of the clock signal, so that consecutive read and write 
25 burst operations are capable to be performed sequentially in any order with the 
respective read and write addresses being received by the memory circuit in 
consecutive clock cycles, without any dead clock cycles therebetween. 
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55. The memory circuit of Claim 54 wherein receiving an address in 
one burst operation is capable to overlap with receiving or providing data in a 
previous burst operation. 

5 56. A memory circuit comprising: 

a clock terminal for receiving a clock signal; 

a first address bus for receiving an address; 

a data bus for receiving write data and providing read data; 

two or more memory blocks for storing data, wherein each memory block 
10 has a second address bus for receiving an address of a location in the memory 
block; 

a plurality of registers for passing the address from the first address bus to 
the first and second memory blocks on consecutive edges of the clock signal; 

a temporary storage for storing write data before the write data are written 
15 to at least one of the memory blocks, and for storing a write address before 
providing the write address to at least one of the memory blocks; 

wherein in write operation immediately preceding a read operation, the 
temporary storage circuit stores the write operation's write data until a subsequent 
write operation; and 

20 the memory further comprises a comparator for comparing a read address 

with the write address stored in the temporary storage, and for providing read data 
to the data bus from the temporary storage instead of the memory blocks if the 
comparator indicates a match. 
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DOUBLE DATA RATE SYNCHRONOUS SRAM 
WITH 100% BUS UTILIZATION 

5 Stanley A. Hronik 

ABSTRACT OF THE INVENTION 

A synchronous memory circuit is capable of double data transfer rate per 
clock cycle, 100% bus utilization (i.e., no idle clock cycles in bus turn arounds), 

10 and has only one clock cycle of latency in each of read and write burst operations. 
The memory circuit has a data bus 202, at least two memory blocks (20, 30), a 
multiplexer (120) for receiving two read data items from respective two memory 
blocks in a read burst operation and allowing one of the two read data items to be 
provided on the data bus half a clock cycle after the read burst operation is initiated 

15 and allowing the other one of the two read data items to be provided on the data 
bus one clock cycle after the read burst operation is initiated, and two registers (50, 
70) for storing respective two write data items provided on the data bus in a first 
write burst operation wherein one of the two write data items is written to one of 
the two memory blocks at the initiation of a next write burst operation following 

20 the first write burst operation and the other one of the two write data items is 
written to the other one of the two memory blocks half a clock cycle after the 
initiation of the next write burst operation, wherein in two consecutive clock cycles 
the two write data items are capable of being transferred to the memory circuit via 
the data bus and the two read data items are capable of being transferred from the 

25 memory circuit via the data bus. 
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listed below and, insofar as the subject matter of each of the claims of this application is not 
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disclosed in the prior application(s) in the manner provided by the first paragraph of Title 35, 
United States Code, § 1 12, 1 acknowledge the duty to disclose information, which is material 
to patentability as defined in Title 37, Code of Federal Regulations, § 1.56, which became 
available between the filing date of the prior application(s) and the national or PCT 
international filing date of this application: 


Application Serial No. 

Filing Date 

Status (patented, pending, 
abandoned) 

N/A 




I hereby appoint the following attorney(s) and/or agent(s) to prosecute this application and to 
transact all business in the United States Patent and Trademark Office connected therewith: 


Alan H. MacPherson (24,423); Brian D. Ogonowsky (31,988); David W. Heid (25,875); 
Norman R. Klivans (33,003); Edward C. Kwok (33,938); David E. Steuber (25,557); Michael 
Shenker (34,250); Stephen A. Terrile (32,946); Peter H. Kang (40,350); Ronald J. Meetin 
(29,089); Ken John Koestner (33,004); Omkar K. Suryadevara (36,320); David T. Millers 
(37,396); Kent B. Chambers (38,839); Michael P. Adams (34,763); Robert B. Morrill 
(43,817); Michael J. Halbert (40,633); Gary J. Edwards (41,008); William B. Tiffany (41,347); 
James E. Parsons (34,691); Daniel P. Stewart (41,332); Philip W. Woo (39,880); John T. 
Winburn (26,822); Tom Chen (42,406); Fabio E. Marino (43,339); William W. Holloway 
(26,182); Elaine H. Lo (41,158); Don C. Lawrence (31,975); Marc R. Ascolese (42,268); 
Carmen C. Cook (42,433); David G. Dolezal (41,71 1); Roberta P. Saxon (43,087); Bernice 
Chen (42,403); Mary Jo Bertani (42,321); Dale R. Cook (42,434); Sam G. Campbell (42,381); 
Matthew J. Brigham (44,047); Glen B. Choi (43,546); Hugh H. Matsubayashi (43,779); 
Margaret M. Kelton (44,182); Joseph T. VanLeeuwen (44,383); William C. Cray (27,627); 
Patrick D. Benedicto (40,909); T.J. Singh (39,535); Shireen I. Bacon (40,494); Rory G. Bens 
(44,028); George Wolken, Jr. (30,441); and Isabelle R. McAndrews (34,998). 

Please address all correspondence and telephone calls to: 

Michael Shenker 
Attorney for Applicant(s) 
SKJERVEN, MORRILL, MacPHERSON, FRANKLIN & FRIEL LLP 

25 Metro Drive, Suite 700 
San Jose, California 95 1 1 0-1 349 

Telephone: 408-453-9200 
Facsimile: 408-453-7979 

I declare that all statements made herein of my own knowledge are true, all statements made 
herein on information and belief are believed to be true, and all statements made herein are 
made with the knowledge that whoever, in any matter within the jurisdiction of the Patent and 
Trademark Office, knowingly and willfully falsifies, conceals, or covers up by any trick, 
scheme, or device a material fact, or makes any false, fictitious or fraudulent statements or 
representations, or makes or uses any false writing or document knowing the same to contain 
any false, fictitious or fraudulent statement or entry, shall be subject to the penalties including 
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fine or imprisonment or both as set forth under 18 U.S.C. 1001, and that violations of this 
paragraph may jeopardize the validity of the application or this document, or the validity or 
enforceability of any patent, trademark registration, or certificate resulting therefrom. 


Full name of sole inventor: 

Stanley A. HRONIK 

Inventor's Signature: 


Date:L^^/ 


Residence: 

Sunnyvale, California 



Post Office Address: 

530 Lawrence Expressway, #421 
Sunnyvale, CA 94086 

Citizenship: 

USA 
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